package com.liang;

import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.*;

/**
 * 一、线程池：提供了一个线程队列，队列中保存着所有等待状态的线程。避免了创建与销毁额外开销，提高了响应的速度。
 * 二、线程池的体系结构：
 * 	java.util.concurrent.Executor : 负责线程的使用与调度的根接口
 * 		|--**ExecutorService 子接口: 线程池的主要接口
 * 			|--ThreadPoolExecutor 线程池的实现类
 * 			|--ScheduledExecutorService 子接口：负责线程的调度
 * 				|--ScheduledThreadPoolExecutor ：继承 ThreadPoolExecutor， 实现 ScheduledExecutorSe
 *
 * 三、工具类 : Executors
 * ExecutorService newFixedThreadPool() : 创建固定大小的线程池
 * ExecutorService newCachedThreadPool() : 缓存线程池，线程池的数量不固定，可以根据需求自动的更改数量。
 * ExecutorService newSingleThreadExecutor() : 创建单个线程池。线程池中只有一个线程
 *
 * ScheduledExecutorService newScheduledThreadPool() : 创建固定大小的线程，可以延迟或定时的执行任务。
 *
 * @author: Liangxp
 * @date: 2019/8/3 12:49
 */
public class TestThreadPool11 {
    public static void main(String[] args) throws ExecutionException, InterruptedException {
        // 1.创建一个线程池
        ExecutorService pool = Executors.newFixedThreadPool(5);

        // 2.1 为线程池中的线程分配任务
        ThreadPoolDemo task = new ThreadPoolDemo();
        for (int i = 0; i < 100; i++) {
            pool.submit(task);
        }

        // 2.2为线程池分配有返回值的任务
        List<Future<Integer>> futureList = new ArrayList<>();
        for (int i = 0; i < 10; i++) {
            Future<Integer> future = pool.submit(new Callable<Integer>() {
                @Override
                public Integer call() throws Exception {
                    int sum = 0;
                    for (int i = 0; i <= 100; i++) {
                        sum += i;
                    }
                    return sum;
                }
            });

            futureList.add(future);
        }

        // 3.关闭线程池
        pool.shutdown();

        // 4.拿到任务运算结果
        for (Future<Integer> future : futureList) {
            System.out.println(future.get());
        }

    }
}

class ThreadPoolDemo implements Runnable {

    private int num = 0;

    @Override
    public void run() {
       while (num < 500) {
           System.out.println(Thread.currentThread().getName() + ":" + num++);
       }
    }
}
